今天宠物迷的小编给各位宠物饲养爱好者分享mysql设置表的主键的宠物知识,其中也会对mysql表中一个表中可以有多个主键吗?(一个数据表可以有多个主键)进行专业的解释,如果能碰巧解决你现在面临的宠物相关问题,别忘了关注本站哦,现在我们开始吧!
主键只能有一个。 但是,如果你想用多个‘唯一索引’(unique index),是可以有多个的。 主键的作用是保证数据的唯一性和完整性,同时通过主键检索表能够增加检索速度。 所谓的一张表多个主键,我们称之为联合主键。 可以由多个列形成联合主键,但是主键只能有一个
mysql设置主键的代码是PRIMARY KEY (主键字段)。 如:CREATE TABLE Customer (SID integer,Last_Name varchar(30),First_Name varchar(30),PRIMARY KEY (SID))。 主关键字(主键,primary key)是被挑选出来,作表的行的唯一标识的候选关键字。一个表只有一个主关键字。主关键字又可以称为主键。 扩展资料: 永远也不要更新主键。实际上,因为主键除了唯一地标识一行之外,再没有其他的用途了,所以也就没有理由去对它更新。如果主键需要更新,则说明主键应对用户无意义的原则被违反了。 主键应当由计算机自动生成。如果由人来对主键的创建进行干预,就会使它带有除了唯一标识一行以外的意义。一旦越过这个界限,就可能产生人为修改主键的动机,这样,这种系统用来链接记录行、管理记录行的关键手段就会落入不了解数据库设计的人的手中。
1.外键的作用,主要有两个:
一个是让数据库自己通过外键来保证数据的完整性和一致性
一个就是能够增加ER图的可读性
2.外键的配置
1)先创建一个主表,代码如下:
#创建表student,并添加各种约束
create table student
(
id int primary key , #主键约束
name varchar(20) , #唯一约束
age int NOT NULL, #非空约束
sex varchar(2) ,
address varchar(20) default '重庆' #默认约束
) ;
再通过一个外键,创建一个分数表,这样的话,就可以方便查询。代码如下:
#创建分数表
create table score
(
id int primary key ,
sid int ,
china int ,
history int,
english int,
constraint FK_sid foreign key(sid) references student(id) #通过外键创建链接
) ;
创建外键的方法有很多,其中最常见创建外键的格式是:constraint FK_*** foreign key(**) references 链接的外表
删除外键:
alter table drop foreign key '外键名'.
注意:
只有在定义外键时,用constraint 外键名 foreign key .... 方便进行外键的删除
主键是唯一标示这一行的,就好像你的***号一样,每个人只有一个,也是唯一能证明你是你的东西。外键是别人执行你的东西。也就是说如果一个人想和你有点关系怎么办,那就要关联起来,怎么关联起来,就通过外键啊
定义主键和外键主要是为了维护关系数据库的完整性,总结一下:
一、主键是能确定一条记录的唯一标识,比如,一条记录包括身份正号,姓名,年龄。***号是唯一能确定你这个人的,其他都可能有重复,所以,***号是主键。
外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。
ALTER TABLE `category` MODIFY `id` INT PRIMARY KEY AUTO_INCREMENT;或者ALTER TABLE `category` CHANGE `id` INT PRIMARY KEY AUTO_INCREMENT;
ALTER TABLE `category` MODIFY `id` INT PRIMARY KEY AUTO_INCREMENT;或者ALTER TABLE `category` CHANGE `id` INT PRIMARY KEY AUTO_INCREMENT;
sql语句后面加注释
给你个例子
CREATE TABLE `test` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`test` varchar(11) NOT NULL COMMENT '这里是字段注释',
PRIMARY KEY (`id`)
) ENGINE=MyISAM COMMENT=这里是表名注释';
能,MySQL 每张表只能有1个自动增长字段,这个自动增长字段即可作为主键,也可以用作非主键使用,但是请注意将自动增长字段当做非主键使用时必须必须为其添加唯一索引,否则系统将会报错。例如:
-- 将自动增长字段设置为主键
create table t1 (id int auto_increment Primary key,sid int);
-- 将自动增长字段设置为非主键,注意必须显式添加Unique键
create table t2 (sid int primary key,id int auto_increment Unique);
-- **将自动增长字段设置为非主键如果未添加唯一索引将会报错**,如下面语句
create table t3 (sid int primary key,id int auto_increment);
就我所知这个好像无法实现,就算你自己编译mysql恐怕也很难。因为last_insert_id()这个内置的函数返回最近一次插入的自增长ID,当没有符合条件的ID时,它返回0,所以如果自增长从0开始的话,这个返回值就很难判定到底是插入了一条自增长ID为0的记录还是没有符合条件的记录了。
本文由宠物迷 百科常识栏目发布,非常欢迎各位朋友分享到个人朋友圈,但转载请说明文章出处“mysql表中一个表中可以有多个主键吗?”
上一篇
狗狗胆小的原因及克服的方法
下一篇
电子书怎么下载到手机上